**ADD** 

Add register/immediate

Add

[Instruction format] (1) ADD reg1, reg2

(2) ADD imm5, reg2

[Operation] (1) GR [reg2]  $\leftarrow$  GR [reg2] + GR [reg1]

(2) GR [reg2] ← GR [reg2] + sign-extend (imm5)

[Format] (1) Format I

(2) Format II

[Opcode]

(1) rrrrr001110RRRRR

15 0
(2) rrrrr010010iiiii

[Flags] CY "1" if a carry occurs from MSB; otherwise, "0".

OV "1" if overflow occurs; otherwise, "0".

S "1" if the operation result is negative; otherwise, "0".

Z "1" if the operation result is "0"; otherwise, "0".

SAT --

[Description]

- (1) Adds the word data of general-purpose register reg1 to the word data of general-purpose register reg2 and stores the result in general-purpose register reg2. General-purpose register reg1 is not affected.
- (2) Adds the 5-bit immediate data, sign-extended to word length, to the word data of general-purpose register reg2 and stores the result in general-purpose register reg2.

<Branch instruction>

Branch on condition code with 9-bit displacement

**Bcond** 

Conditional branch

[Instruction format] Bcond disp9

[Operation] if conditions are satisfied

then  $PC \leftarrow PC + sign-extend (disp9)$ 

[Format] Format III

[Opcode] 15 (ddddd1011dddcccc

ddddddd is the higher 8 bits of disp9.

cccc is the condition code of the condition indicated by cond (refer to Table 5-5 Bcond

Instructions).

[Flags] CY --

OV --S --

SAT --

Ζ

[Description] Checks each PSW flag specified by the instruction and branches if a condition is met; otherwise,

executes the next instruction. The PC of branch destination is the sum of the current PC value and

the 9-bit displacement (= 8-bit immediate data shifted by 1 and sign-extended to word length).

[Comment] Bit 0 of the 9-bit displacement is masked to "0". The current PC value used for calculation is the

address of the first byte of this instruction. The displacement value being "0" signifies that the

branch destination is the instruction itself.



Table 5-5. Boond Instructions

| Ins      | truction | Condition Code (cccc) | Flag Status                         | Branch Condition                  |  |  |
|----------|----------|-----------------------|-------------------------------------|-----------------------------------|--|--|
| Signed   | BGE      | 1110                  | (S xor OV) = 0                      | Greater than or equal to signed   |  |  |
| integer  | BGT      | 1111                  | $((S \times OV) \text{ or } Z) = 0$ | Greater than signed               |  |  |
|          | BLE      | 0111                  | ( (S xor OV) or Z) = 1              | Less than or equal to signed      |  |  |
|          | BLT      | 0110                  | (S xor OV) = 1                      | Less than signed                  |  |  |
| Unsigned | ВН       | 1011                  | (CY  or  Z) = 0                     | Higher (Greater than)             |  |  |
| integer  | BL       | 0001                  | CY = 1                              | Lower (Less than)                 |  |  |
|          | BNH      | 0011                  | (CY or Z) = 1                       | Not higher (Less than or equal)   |  |  |
|          | BNL      | 1001                  | CY = 0                              | Not lower (Greater than or equal) |  |  |
| Common   | BE       | 0010                  | Z = 1                               | Equal                             |  |  |
|          | BNE      | 1010                  | Z = 0                               | Not equal                         |  |  |
| Others   | ВС       | 0001                  | CY = 1                              | Carry                             |  |  |
|          | BF       | 1010                  | Z = 0                               | False                             |  |  |
|          | BN       | 0100                  | S = 1                               | Negative                          |  |  |
|          | BNC      | 1001                  | CY = 0                              | No carry                          |  |  |
|          | BNV      | 1000                  | OV = 0                              | No overflow                       |  |  |
|          | BNZ      | 1010                  | Z = 0                               | Not zero                          |  |  |
|          | BP       | 1100                  | S = 0                               | Positive                          |  |  |
|          | BR       | 0101                  | -                                   | Always (unconditional)            |  |  |
|          | BSA      | 1101                  | SAT = 1                             | Saturated                         |  |  |
|          | ВТ       | 0010                  | Z = 1                               | True                              |  |  |
|          | BV       | 0000                  | OV = 1                              | Overflow                          |  |  |
|          | BZ       | 0010                  | Z = 1                               | Zero                              |  |  |

#### Caution

The branch condition loses its meaning if a conditional branch instruction is executed on a signed integer (BGE, BGT, BLE, or BLT) when the saturated operation instruction sets "1" to the SAT flag. In normal operations, if an overflow occurs, the S flag is inverted ( $0 \rightarrow 1$  or  $1 \rightarrow 0$ ). This is because the result is a negative value if it exceeds the maximum positive value and it is a positive value if it exceeds the maximum negative value. However, when a saturated operation instruction is executed, and if the result exceeds the maximum positive value, the result is saturated with a positive value; if the result exceeds the maximum negative value, the result is saturated with a negative value. Unlike the normal operation, the S flag is not inverted even if an overflow occurs.

#### <Branch instruction>

**JMP** 

Jump register

Unconditional branch (register relative)

[Instruction format]

- (1) JMP [reg1]
- (2) JMP disp32 [reg1]

[Operation]

- (1) PC ← GR [reg1]
- (2) PC ← GR [reg1] + disp32

[Format]

- (1) Format I
- (2) Format VI

[Opcode]





DDDDDDDDDDDDDDDDDddddddddddddd is the higher 31 bits of disp32.

[Flags]

CY

OV

S

Ζ

SAT

[Description]

- (1) Transfers the control to the address specified by general-purpose register reg1. Bit 0 of the address is masked to "0".
- (2) Adds the 32-bit displacement to general-purpose register reg1, and transfers the control to the resulting address. Bit 0 of the address is masked to "0".

[Comment]

Using this instruction as the subroutine control instruction requires the return PC to be specified by general-purpose register reg1.

MOV

Move register/immediate (5-bit) /immediate (32-bit)

Data transfer

[Instruction format]

- (1) MOV reg1, reg2
- (2) MOV imm5, reg2
- (3) MOV imm32, reg1

[Operation]

- (1) GR [reg2] ← GR [reg1]
- (2) GR [reg2] ← sign-extend (imm5)
- (3) GR [reg1] ← imm32

[Format]

- (1) Format I
- (2) Format II
- (3) Format VI

[Opcode]



rrrrr ≠ 00000 (Do not specify r0 for reg2.)

rrrrr ≠ 00000 (Do not specify r0 for reg2.)

|     | 15 0             | 31             | 16 47           | 32 |
|-----|------------------|----------------|-----------------|----|
| (3) | 00000110001RRRRR | iiiiiiiiiiiiii | ii IIIIIIIIIIII | ΞI |

- i (bits 31 to 16) refers to the lower 16 bits of 32-bit immediate data.
- I (bits 47 to 32) refers to the higher 16 bits of 32-bit immediate data.

[Flags]

CY -

OV --

S --

Z -

SAT -

[Description]

- (1) Copies and transfers the word data of general-purpose register reg1 to general-purpose register reg2. General-purpose register reg1 is not affected.
- (2) Copies and transfers the 5-bit immediate data, sign-extended to word length, to general-purpose register reg2.
- (3) Copies and transfers the 32-bit immediate data to general-purpose register reg1.

Caution

Do not specify r0 as reg2 in MOV reg1, reg2 for instruction format (1) or in MOV imm5, reg2 for instruction format (2).

<Special instruction>

NOP

No operation

No operation

[Instruction format] NOP

[Operation] PC for this instruction is incremented by +2 (nothing else is done).

[Format] Format I

[Opcode] 00000000000000000

CY [Flags]

> $\mathsf{OV}$ S Ζ

SAT

[Description] PC for this instruction is incremented by +2 (nothing else is done).

RENESAS

[Comment] The opcode is the same as that of MOV r0, r0.

Subtract **SUB** Subtraction

[Instruction format] SUB reg1, reg2

[Operation]  $GR [reg2] \leftarrow GR [reg2] - GR [reg1]$ 

Format I [Format]

[Opcode] 15 rrrr001101RRRRR

CY "1" if a borrow occurs from MSB; otherwise, "0". [Flags]

> "1" if overflow occurs; otherwise, "0".  $\mathsf{OV}$

S "1" if the operation result is negative; otherwise, "0".

Ζ "1" if the operation result is "0"; otherwise, "0".

SAT

[Description] Subtracts the word data of general-purpose register reg1 from the word data of general-purpose

register reg2 and stores the result in general-purpose register reg2. General-purpose register reg1

is not affected.

**SUBR** 

Subtract reverse

Reverse subtraction

[Instruction format] SUBR reg1, reg2

[Operation] GR [reg2]  $\leftarrow$  GR [reg1] – GR [reg2]

[Format] Format I

[Opcode] 15 0 rrrrr001100RRRRR

[Flags] CY "1" if a borrow occurs from MSB; otherwise, "0".

OV "1" if overflow occurs; otherwise, "0".

S "1" if the operation result is negative; otherwise, "0".

Z "1" if the operation result is "0"; otherwise, "0".

SAT --

[Description] Subtracts the word data of general-purpose register reg2 from the word data of general-purpose

register reg1 and stores the result in general-purpose register reg2. General-purpose register reg1

is not affected.

# APPENDIX A LIST OF INSTRUCTIONS

## A.1 Basic Instructions

Table A-1 shows an alphabetized list of basic instruction functions.

Table A-1. Basic Instruction Function List (Alphabetic Order) (1/4)

| Mnemonic | Operand                | Format | at Flag |     |     | Function of Instruction |     |                                                   |
|----------|------------------------|--------|---------|-----|-----|-------------------------|-----|---------------------------------------------------|
|          |                        |        | CY      | OV  | S   | Z                       | SAT |                                                   |
| ADD      | reg1, reg2             | I      | 0/1     | 0/1 | 0/1 | 0/1                     | _   | Add                                               |
| ADD      | imm5, reg2             | II     | 0/1     | 0/1 | 0/1 | 0/1                     | _   | Add                                               |
| ADDI     | imm16, reg1, reg2      | VI     | 0/1     | 0/1 | 0/1 | 0/1                     | _   | Add                                               |
| ADF      | cccc, reg1, reg2, reg3 | ΧI     | 0/1     | 0/1 | 0/1 | 0/1                     | _   | Conditional add                                   |
| AND      | reg1, reg2             | I      | _       | 0   | 0/1 | 0/1                     | _   | AND                                               |
| ANDI     | imm16, reg1, reg2      | VI     | _       | 0   | 0/1 | 0/1                     | _   | AND                                               |
| Bcond    | disp9                  | Ш      | _       | _   | _   | -                       | _   | Conditional branch                                |
| BSH      | reg2, reg3             | XII    | 0/1     | 0   | 0/1 | 0/1                     | -   | Byte swap of halfword data                        |
| BSW      | reg2, reg3             | XII    | 0/1     | 0   | 0/1 | 0/1                     | _   | Byte swap of word data                            |
| CALLT    | imm6                   | II     | _       | _   | _   | -                       | _   | Subroutine call with table look up                |
| CAXI     | [reg1], reg2, reg3     | IX     | 0/1     | 0/1 | 0/1 | 0/1                     | _   | Comparison and swap                               |
| CLR1     | bit#3, disp16 [reg1]   | VIII   | _       | _   | _   | 0/1                     | _   | Bit clear                                         |
| CLR1     | reg2, [reg1]           | IX     | _       | _   | _   | 0/1                     | _   | Bit clear                                         |
| CMOV     | cccc, reg1, reg2, reg3 | XI     | _       | _   | _   | _                       | _   | Conditional transfer                              |
| CMOV     | cccc, imm5, reg2, reg3 | XII    | _       | -   | -   | -                       | _   | Conditional transfer                              |
| CMP      | reg1, reg2             | I      | 0/1     | 0/1 | 0/1 | 0/1                     | _   | Comparison                                        |
| CMP      | imm5, reg2             | II     | 0/1     | 0/1 | 0/1 | 0/1                     | _   | Comparison                                        |
| CTRET    | (None)                 | Χ      | 0/1     | 0/1 | 0/1 | 0/1                     | 0/1 | Return from subroutine call                       |
| DI       | (None)                 | Χ      | _       | _   | _   | _                       | _   | Disable EI level maskable exception               |
| DISPOSE  | imm5, list12           | XIII   | _       | -   | _   | -                       | _   | Stack frame deletion                              |
| DISPOSE  | imm5, list12, [reg1]   | XIII   | _       | _   | -   | -                       | _   | Stack frame deletion                              |
| DIV      | reg1, reg2, reg3       | ΧI     | _       | 0/1 | 0/1 | 0/1                     | _   | Division of (signed) word data                    |
| DIVH     | reg1, reg2             | I      | _       | 0/1 | 0/1 | 0/1                     | _   | Division of (signed) halfword data                |
| DIVH     | reg1, reg2, reg3       | ΧI     | _       | 0/1 | 0/1 | 0/1                     | _   | Division of (signed) halfword data.               |
| DIVHU    | reg1, reg2, reg3       | XI     | _       | 0/1 | 0/1 | 0/1                     | _   | Division of (unsigned) halfword data              |
| DIVQ     | reg1, reg2, reg3       | ΧI     | _       | 0/1 | 0/1 | 0/1                     | _   | Division of (signed) word data (variable steps)   |
| DIVQU    | reg1, reg2, reg3       | ΧI     | _       | 0/1 | 0/1 | 0/1                     | _   | Division of (unsigned) word data (variable steps) |
| DIVU     | reg1, reg2, reg3       | ΧI     | _       | 0/1 | 0/1 | 0/1                     | _   | Division of (unsigned) word data                  |

Table A-1. Basic Instruction Function List (Alphabetic Order) (2/4)

| Mnemonic | Operand                | Format |       |     | Flag |     |     | Function of Instruction                            |
|----------|------------------------|--------|-------|-----|------|-----|-----|----------------------------------------------------|
|          |                        |        | CY OV |     | S Z  |     | SAT |                                                    |
| EI       | (None)                 | Х      | =     | _   | _    | -   | -   | Enable El level maskable exception                 |
| EIRET    | (None)                 | Х      | 0/1   | 0/1 | 0/1  | 0/1 | 0/1 | Return from El level exception                     |
| FERET    | (None)                 | Х      | 0/1   | 0/1 | 0/1  | 0/1 | 0/1 | Return from FE level exception                     |
| FETRAP   | vector                 | I      | _     | _   | -    | _   | _   | FE level software exception instruction            |
| HALT     | (None)                 | Х      | _     | _   | _    | _   | -   | Halt                                               |
| HSH      | reg2, reg3             | XII    | 0/1   | 0   | 0/1  | 0/1 | -   | Halfword swap of halfword data                     |
| HSW      | reg2, reg3             | XII    | 0/1   | 0   | 0/1  | 0/1 | -   | Halfword swap of word data                         |
| JARL     | disp22, reg2           | ٧      | _     | _   | _    | _   | -   | Branch and register link                           |
| JARL     | disp32, reg1           | VI     | _     | _   | _    | -   | _   | Branch and register link                           |
| JMP      | [reg1]                 | I      | _     | _   | _    | -   | _   | Unconditional branch (register relative)           |
| JMP      | disp32 [reg1]          | VI     | _     | _   | _    | _   | _   | Unconditional branch (register relative)           |
| JR       | disp22                 | V      | _     | _   | _    | -   | _   | Unconditional branch (PC relative)                 |
| JR       | disp32                 | VI     | _     | _   | _    | -   | _   | Unconditional branch (PC relative)                 |
| LD.B     | disp16 [reg1], reg2    | VII    | _     | _   | _    | -   | _   | Load of (signed) byte data                         |
| LD.B     | disp23 [reg1], reg3    | XIV    | _     | _   | _    | -   | _   | Load of (signed) byte data                         |
| LD.BU    | disp16 [reg1], reg2    | VII    | _     | _   | _    | -   | _   | Load of (unsigned) byte data                       |
| LD.BU    | disp23 [reg1], reg3    | XIV    | _     | _   | _    | -   | _   | Load of (unsigned) byte data                       |
| LD.H     | disp16 [reg1], reg2    | VII    | _     | _   | _    | _   | _   | Load of (signed) halfword data                     |
| LD.H     | disp23 [reg1], reg3    | XIV    | _     | _   | _    | _   | _   | Load of (signed) halfword data                     |
| LD.HU    | disp16 [reg1], reg2    | VII    | _     | _   | _    | _   | _   | Load of (unsigned) halfword data                   |
| LD.HU    | disp23 [reg1], reg3    | XIV    | _     | _   | _    | _   | _   | Load of (unsigned) halfword data                   |
| LD.W     | disp16 [reg1], reg2    | VII    | -     | _   | _    | _   | -   | Load of word data                                  |
| LD.W     | disp23 [reg1], reg3    | XIV    | _     | _   | _    | _   |     | Load of word data                                  |
| LDSR     | reg2, regID            | IX     | _     | _   | _    | _   | _   | Load to system register                            |
| MAC      | reg1, reg2, reg3, reg4 | XI     | -     | -   | _    | _   | -   | Multiply-accumulate for (signed) word data         |
| MACU     | reg1, reg2, reg3, reg4 | XI     | _     | _   | _    | _   | _   | Multiply-accumulate for (unsigned) word data       |
| MOV      | reg1, reg2             | I      | -     | -   | _    | _   | -   | Data transfer                                      |
| MOV      | imm5, reg2             | II     | _     | _   | _    | _   | _   | Data transfer                                      |
| MOV      | imm32, reg1            | VI     | _     | _   | _    | _   | _   | Data transfer                                      |
| MOVEA    | imm16, reg1, reg2      | VI     | _     | _   | _    | -   | _   | Effective address transfer                         |
| MOVHI    | imm16, reg1, reg2      | VI     | _     | _   | _    | _   | _   | Higher halfword transfer                           |
| MUL      | reg1, reg2, reg3       | XI     | -     | -   | -    | -   | -   | Multiplication of (signed) word data               |
| MUL      | imm9, reg2, reg3       | XII    | _     | _   | -    | -   | -   | Multiplication of (signed) word data               |
| MULH     | reg1, reg2             | I      | -     | -   | -    | -   | -   | Multiplication of (signed) halfword data           |
| MULH     | imm5, reg2             | II     | _     | _   | -    | -   | -   | Multiplication of (signed) halfword data           |
| MULHI    | imm16, reg1, reg2      | VI     | _     | _   | _    | _   | -   | Multiplication of (signed) halfword immediate data |

Table A-1. Basic Instruction Function List (Alphabetic Order) (3/4)

| Mnemonic | Operand                | Format |     | Flag |     |     | Function of Instruction |                                                      |
|----------|------------------------|--------|-----|------|-----|-----|-------------------------|------------------------------------------------------|
|          |                        |        | CY  | OV   | S   | Ζ   | SAT                     |                                                      |
| MULU     | reg1, reg2, reg3       | ΧI     | _   | _    | _   | _   | _                       | Multiplication of (unsigned) word data               |
| MULU     | imm9, reg2, reg3       | XII    | _   | _    | _   | _   | _                       | Multiplication of (unsigned) word data               |
| NOP      | (None)                 | I      | _   | _    | -   | _   | _                       | Nothing else is done.                                |
| NOT      | reg1, reg2             | I      | _   | 0    | 0/1 | 0/1 | -                       | Logical negation (1's complement)                    |
| NOT1     | bit#3, disp16 [reg1]   | VIII   | _   | _    | _   | 0/1 | -                       | NOT bit                                              |
| NOT1     | reg2, [reg1]           | IX     | _   | _    | -   | 0/1 | -                       | NOT bit                                              |
| OR       | reg1, reg2             | I      | _   | 0    | 0/1 | 0/1 | -                       | OR                                                   |
| ORI      | imm16, reg1, reg2      | VI     | _   | 0    | 0/1 | 0/1 | -                       | OR immediate                                         |
| PREPARE  | list12, imm5           | XIII   | _   | _    | _   | _   | -                       | Create stack frame                                   |
| PREPARE  | list12, imm5, sp/imm   | XIII   | _   | _    | -   | -   | -                       | Create stack frame                                   |
| RETI     | (None)                 | Х      | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Return from El level software exception or interrupt |
| RIE      | (None)                 | I/X    | _   | _    | _   | _   | -                       | Reserved instruction exception                       |
| SAR      | reg1, reg2             | IX     | 0/1 | 0    | 0/1 | 0/1 | -                       | Arithmetic right shift                               |
| SAR      | imm5, reg2             | II     | 0/1 | 0    | 0/1 | 0/1 | -                       | Arithmetic right shift                               |
| SAR      | reg1, reg2, reg3       | XI     | 0/1 | 0    | 0/1 | 0/1 | -                       | Arithmetic right shift                               |
| SASF     | cccc, reg2             | IX     | _   | _    | _   | _   | -                       | Shift and flag condition setting                     |
| SATADD   | reg1, reg2             | I      | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Saturated addition                                   |
| SATADD   | imm5, reg2             | II     | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Saturated addition                                   |
| SATADD   | reg1, reg2, reg3       | XI     | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Saturated addition                                   |
| SATSUB   | reg1, reg2             | I      | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Saturated subtraction                                |
| SATSUB   | reg1, reg2, reg3       | XI     | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Saturated subtraction                                |
| SATSUBI  | imm16, reg1, reg2      | VI     | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Saturated subtraction                                |
| SATSUBR  | reg1, reg2             | I      | 0/1 | 0/1  | 0/1 | 0/1 | 0/1                     | Saturated reverse subtraction                        |
| SBF      | cccc, reg1, reg2, reg3 | XI     | 0/1 | 0/1  | 0/1 | 0/1 | _                       | Conditional subtraction                              |
| SCH0L    | reg2, reg3             | IX     | 0/1 | 0    | 0   | 0/1 | _                       | Bit (0) search from MSB side                         |
| SCH0R    | reg2, reg3             | IX     | 0/1 | 0    | 0   | 0/1 | _                       | Bit (0) search from LSB side                         |
| SCH1L    | reg2, reg3             | IX     | 0/1 | 0    | 0   | 0/1 | _                       | Bit (1) search from MSB side                         |
| SCH1R    | reg2, reg3             | IX     | 0/1 | 0    | 0   | 0/1 | _                       | Bit (1) search from LSB side                         |
| SET1     | bit#3, disp16 [reg1]   | VIII   | _   | _    | -   | 0/1 | _                       | Bit setting                                          |
| SET1     | reg2, [reg1]           | IX     | _   | _    | -   | 0/1 | _                       | Bit setting                                          |
| SETF     | cccc, reg2             | IX     | _   | _    | _   |     |                         | Flag condition setting                               |
| SHL      | reg1, reg2             | IX     | 0/1 | 0    | 0/1 | 0/1 |                         | Logical left shift                                   |
| SHL      | imm5, reg2             | II     | 0/1 | 0    | 0/1 | 0/1 |                         | Logical left shift                                   |
| SHL      | reg1, reg2, reg3       | XI     | 0/1 | 0    | 0/1 | 0/1 |                         | Logical left shift                                   |

Table A-1. Basic Instruction Function List (Alphabetic Order) (4/4)

| Mnemonic | Operand              | Format |       |     | Flag |     |   | Function of Instruction                |
|----------|----------------------|--------|-------|-----|------|-----|---|----------------------------------------|
|          | •                    |        | CY OV |     | S    | S Z |   |                                        |
| SHR      | reg1, reg2           | IX     | 0/1   | 0   | 0/1  | 0/1 | - | Logical right shift                    |
| SHR      | imm5, reg2           | II     | 0/1   | 0   | 0/1  | 0/1 | _ | Logical right shift                    |
| SHR      | reg1, reg2, reg3     | ΧI     | 0/1   | 0   | 0/1  | 0/1 | _ | Logical right shift                    |
| SLD.B    | disp7 [ep], reg2     | IV     | _     | _   | -    | -   | _ | Load of (signed) byte data             |
| SLD.BU   | disp4 [ep], reg2     | IV     | _     | _   | -    | -   | _ | Load of (unsigned) byte data           |
| SLD.H    | disp8 [ep], reg2     | IV     | _     | _   | -    | -   | _ | Load of (signed) halfword data         |
| SLD.HU   | disp5 [ep], reg2     | IV     | _     | _   | -    | -   | _ | Load of (unsigned) halfword data       |
| SLD.W    | disp8 [ep], reg2     | IV     | _     | _   | -    | -   | _ | Load of word data                      |
| SST.B    | reg2, disp7 [ep]     | IV     | _     | _   | -    | -   | _ | Storage of byte data                   |
| SST.H    | reg2, disp8 [ep]     | IV     | _     | _   | -    | -   | _ | Storage of halfword data               |
| SST.W    | reg2, disp8 [ep]     | IV     | _     | _   | -    | -   | _ | Storage of word data                   |
| ST.B     | reg2, disp16 [reg1]  | VII    | _     | _   | -    | -   | _ | Storage of byte data                   |
| ST.B     | reg3, disp23 [reg1]  | XIV    | _     | _   | _    | _   | - | Storage of byte data                   |
| ST.H     | reg2, disp16 [reg1]  | VII    | _     | _   | _    | _   | - | Storage of halfword data               |
| ST.H     | reg3, disp23 [reg1]  | XIV    | _     | _   | _    | _   | - | Storage of halfword data               |
| ST.W     | reg2, disp16 [reg1]  | VII    | _     | _   | _    | _   | - | Storage of word data                   |
| ST.W     | reg3, disp23 [reg1]  | XIV    | _     | _   | _    | _   | - | Storage of word data                   |
| STSR     | regID, reg2          | IX     | _     | _   | _    | _   | - | Storage of contents of system register |
| SUB      | reg1, reg2           | I      | 0/1   | 0/1 | 0/1  | 0/1 | _ | Subtraction                            |
| SUBR     | reg1, reg2           | I      | 0/1   | 0/1 | 0/1  | 0/1 | _ | Reverse subtraction                    |
| SWITCH   | reg1                 | I      | _     | _   | -    | -   | _ | Jump with table look up                |
| SXB      | reg1                 | I      | _     | _   | _    | _   | - | Sign-extension of byte data            |
| SXH      | reg1                 | I      | _     | _   | _    | _   | - | Sign-extension of halfword data        |
| SYNCE    | (None)               | I      | _     | _   | _    | _   | - | Exception synchronize instruction      |
| SYNCM    | (None)               | I      | _     | _   | -    | -   | _ | Memory synchronize instruction         |
| SYNCP    | (None)               | I      | _     | _   | -    | -   | _ | Pipeline synchronize instruction       |
| SYSCALL  | vector8              | Χ      | _     | _   | -    | -   | _ | System call exception                  |
| TRAP     | vector5              | Χ      | _     | _   | -    | -   | _ | Software exception                     |
| TST      | reg1, reg2           | I      | _     | 0   | 0/1  | 0/1 | - | Test                                   |
| TST1     | bit#3, disp16 [reg1] | VIII   | _     | _   | -    | 0/1 | _ | Bit test                               |
| TST1     | reg2, [reg1]         | IX     | -     | -   | -    | 0/1 | - | Bit test                               |
| XOR      | reg1, reg2           | I      | -     | 0   | 0/1  | 0/1 | _ | Exclusive OR                           |
| XORI     | imm16, reg1, reg2    | VI     | _     | 0   | 0/1  | 0/1 | - | Exclusive OR immediate                 |
| ZXB      | reg1                 | I      | -     | _   | -    | -   | _ | Zero-extension of byte data            |
| ZXH      | reg1                 | I      | _     | _   | _    | _   | _ | Zero-extension of halfword data        |